19.01.2022
0
1
76
100

WPO – Wave Period Oscillator

using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using Matriks.Data.Identifiers;
using Matriks.Data.Symbol;
using Matriks.Engines;
using Matriks.Indicators;
using Matriks.Symbols;
using Matriks.AlgoTrader;
using Matriks.Trader.Core;
using Matriks.Trader.Core.Fields;
using Matriks.Trader.Core.TraderModels;
using Matriks.Lean.Algotrader.AlgoBase;
using Matriks.Lean.Algotrader.Models;
using Matriks.Lean.Algotrader.Trading;

/*
period:=input("Period",1,500,14);
Tt:=2*3.14159265359/ATN((ref(c,-1)/H)/Sqr(1-(ref(c,-1)/H)^2));
Ti:=if(roc(c,1,$)>0,tt,-tt);
WPO:=mov(ti,period,e);
WPO;0:2:-2

Kıvanç Özbilgiç
*/
namespace Matriks.Lean.Algotrader
{
	//Ilk parametre indikatörün adı, sınıfın adıyla aynı olmalıdır.
	//Ikinci parametre indikatörün Dataserisinin üzerine mi yeni pencereye mi ekleneceğini belirtir. Yeni pencere için ->IndicatorDrawingArea.NewWindow , Data Serisi için IndicatorDrawingArea.OnDataSeries
	[IndicatorInformationAttribute("WPOKripex", IndicatorDrawingArea.NewWindow)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"WPO"
		})]

	public class WPOKripex : MatriksIndicator
	{

		//Indicator opsiyon panelinde değerleri değiştirebildiğimiz parametreler. Int, Bool, Decimal ve Enum değerleri alabilir.Tüm değişken tiplerini DefaultValue ile tanımlarız. 
		[DefaultValue(14)]
		public int Period
		{
			get; set;
		}

		[DefaultValue(MovMethod.E)]
		public MovMethod movMethod
		{
			get; set;
		}

		ROC roc;

		MOV mov;

		public sealed override void OnInit()
		{
			roc = ROCIndicator(Symbol, SymbolPeriod, OHLCType.Close, 1);

			mov = new MOV(Period, movMethod);

			DrawHorizantal(0);
			DrawHorizantal(2);
			DrawHorizantal(-2);
		}

		decimal tt, ti;

		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{
			if (currentBar < Period)
			{
				SetLine(0, currentBar, 0);
				return ;
			}
			
			var prevClose = Instrument.SymbolBarData.Close[currentBar -1];
			var close = Instrument.SymbolBarData.Close[currentBar];
			var high = Instrument.SymbolBarData.High[currentBar];
			
			var temp = prevClose / high>1?1:(double)(prevClose / high);
			tt = (decimal)(2 * 3.14159265359 / Math.Atan(temp / Math.Sqrt(1 - Math.Pow(temp, 2))));
			
			ti=close-prevClose>0?tt:-1*tt;
			
			mov.Update(ti,currentBar,barDateTime);

			SetLine(0,currentBar, mov.CurrentValue);
		}
	}
}

0 Yorum